// pages/recommendSong/recommendSong.js
import request from '../../../utils/request'
import PubSub from 'pubsub-js'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    day:'',//天
    month:'',//月
    dailySongs:[],//每日推荐的歌曲
    index:0,//点击音乐的下标
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    //判断用户是否登录
    let userInfo = wx.getStorageSync('userInfo')
    if(!userInfo){
      wx.showToast({
        title: '请先登录',
        icon: 'none',
        success:()=>{
          //跳转至登录界面
          wx.reLaunch({
            url: '/pages/login/login',
          })
        }
      })
    }
    //更新日期数据
    this.setData({
      day:new Date().getDate(),
      month:new Date().getMonth()+1,
    })
    //获取每日推荐的歌曲
    this.getDailySongs()
    //订阅来自songDetail的数据
    PubSub.subscribe('getType',(msg,type)=>{
      let {dailySongs,index} = this.data
      if(type === 'pre'){
        //考虑index临界值
        (index===0) && (index = dailySongs.length)
        index -= 1;
      }else{
        (index===dailySongs.length-1) && (index = -1)
        index += 1;
      }
      //要记得更新data里的数据
      this.setData({
        index
      })
      let musicId = dailySongs[index].id;
      //将数据传给songDetail页面
      PubSub.publish('getMusicId',musicId)
    })
  },
  //获取每日推荐的歌曲
  async getDailySongs(){
    let dailySongsData = await request('/recommend/songs')
    this.setData({
      dailySongs:dailySongsData.data.dailySongs
    })
  },
  //跳转至歌曲详情页
  toSongDetail(event){
    let songId = event.currentTarget.dataset.song.id;
    let index = event.currentTarget.dataset.index;
    this.setData({
      index
    })
    wx.navigateTo({
      //可通过query参数传参
      url: '/songPackage/pages/songDetail/songDetail?ids='+songId,
      // 可通过绑定自定义事件传参
      /* success:function(res) {
        res.eventChannel.emit('getSongItem',{songId})
      } */
    })
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})